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MIND OVER MATTER Computers svesuspe tence 
controlled by thought are no longer the turn our attention to the SID 
preserve of science-fiction writers. We look epee er Lal 
at the principles behind this recent using sophisticated software. 
technological development Ew 


mathematical methods for 
controlling our Workshop 
robot arm. : 

© There is a possibility, in our 
New World simulation game, 


AMSTRAD SPIN-OFF The Amstrad that the crew will mutiny. We 
DDI-1 disk drive, supplied with CP/M and 1? show how this contingency is 
Dr LoGo, upgrades the Amstrad CPC 464 to programmed. 

a powerful and economic system 
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THE MIGHTY PEN In our penultimate 
examination of database systems for home 120/ 
micros, we discuss the MicroPen package 


CIPHER CHASE Impossible Mission, from 
Epyx, is a platform game with excellent 1220 
graphics and a ‘race against time’ scenario 
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course now considers PASCAL’S use of file 1204 
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PROGRAMMING PROJECTS 


BATTEN DOWN THE HATCHES We 
develop the routines that deal with the 
remaining four major contingencies in our 
simulation game 









































Editor Stephen Cooke; Deputy Editor Steve Colwill; Art Editor Claudia Zeff; Production Editor Bobby 
Pickering; Designer Julian Dorr; Art Assistant Liz Dixon; Staff Writer Steve Malone; Sub Editor Jon 
Kaye; Contributors Dr Andrew Bangham, Nick Walsh, Dr Antonia Jones, Martin Young, Surya, Steve Malone, 
David Mudd, Anthony Ginn, Steve Colwill, Software Consultants Pilot Software City; Group Art Director Perry 
Neville; Managing Director Stephen England; Published by Orbis Publishing Ltd: Editorial Director Brian 
Innes; Project Development Peter Brookesmith: Executive Editor Maurice Geller, Production Assistant Alastair 
Gourlay; Subscription Manager Christine Allen; Designed and produced by Bunch Partworks Ltd; Editorial Office 
14 Rathbone Place, London W1P 1DE; © APSIF Copenhagen 1985; © Orbis Publishing Ltd 1985: Typeset by 
Universe; Reproduction by Mullis Morgan Ltd; Printed in Great Britain by Heanor Gate Printing Ltd, Derby 


HOW TO OBTAIN ISSUES AND BINDERS FOR THE HOME COMPUTER ADVANCED COURSE - Issues can be obtained by 
placing an order with your newsagent or direct from our subscription department. If you have any difficulty 
obtaining any back issues from your newsagent, please write to us stating the issue(s) required and enclosing a 
cheque for the cover price of the issue(s). AUSTRALIA — please write to: Gordon & Gotch (Aus) Ltd, 114 William 
Street, PO Box 767G, Melbourne, Victoria 3001. MALTA, NEW ZEALAND & SOUTH AFRICA - Back numbers are 
available at cover price from your newsagent. In case of difficulty, write to the address given for binders. 
UK/EIRE - Price: 90p/IR£115. Subscription: 6 months: £26.00. 1 Year: £52.00. Binder: please send £3.95 per 
binder, or take advantage of our special offer in early issues. EUROPE - Price: 90p. Subscription: 6 months air: 
£44.72. Surface: £36.14. 1 year air: £89.44. Surface: £72.28. Binder: £5.00. Airmail: £8.25. MALTA - Obtain 
binders from your newsagent or Miller (Malta) Ltd, MA Vassalli Street, Valetta, Malta. Price: £3.95. MIDDLE EAST - 
Price: 90p. Subscription: 6 months air: £50.18. Surface: £36.14. 1 year air: £100.36. Surface: £72.28. Binder: 
£5.00. Airmail: £8.25. AMERICAS/ASIA/AFRICA — Price: US/CANS1.95/90p. Subscription: 6 months air: £59.54. 
Surface: £36.14. 1 year air: £119.08. Surface: £72.28. Binder: £5.00. Airmail: £9.50. SOUTH AFRICA - Price: SA 
R2.45. Obtain binders from any branch of Central News Agency or Intermag, PO Box 57394, Springfield 2137. 
SINGAPORE - Price: Sing $4.50. Obtain binders from MPH Distributors, 601 Sims Drive, 03-07-21, Singapore 
1438. AUSTRALASIA/FAR EAST - Price: 90p. Subscription: 6 months air: £64.22. Surface: £36.14. 1 year air 
£128.44. Surface: £72.28. Binder: £5.00. Airmail: £9.75. AUSTRALIA — Price: Aus$2.15. Obtain binders from First 
Post Pty Ltd, 23 Chandos Street, St Leonards, NSW 2065. NEW ZEALAND - Price: NZS2.65. Obtain binders from 
your newsagent or Gordon & Gotch (NZ) Ltd, PO Box 1595, Wellington. 
ADDRESS FOR BINDERS AND BACK ISSUES - Orbis Publishing Limited, Orbis House, Bedfordbury, London WC2 
4BT. Telephone 01-379 5211. Cheques/postal orders should be made payable to Orbis Publishing Limited. Binder 
prices include postage and packing and prices are in stirling. Back issues are sold at the cover price, and we do not 
charge carriage in the UK. 

NOTE - Binders and back issues are obtainable subject to availability of stocks. Whilst every attempt is made to 
keep the price of the issues and binders constant, the publishers reserve the right to increase the stated prices at 
any time when circumstances dictate. Binders depicted in this publication are those produced for the UK and 
Australian markets only. Binders and Issues may be subject to import duty and/or local taxes, which are not 
included in the above prices unless stated. 











SPLITTING IMAGE We conclude our 
investigation of the VIC-II’s graphics 1718 
facilities by providing a program that allows 
the Commodore 64’s screen to display high- 
and low-resolution graphics simultaneously 








SINCLAIR’S SINEWS A program for the 
Spectrum to control our robot arm 171 6 
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MIND OVER 





The 


idea of controlling a computer by 
thought sounds like something out of a 
science-fiction movie, but not only is it 
feasible — it’s already a fact. We study the 
phenomenon on which this technology is 
based and look at an input device that links 
the human nervous system to a computer. 





From the days of the first computers the keyboard 
has been the primary input device, the means of 
getting information into a computer. It’s probably 
the most efficient method of entering text and, toa 
lesser extent, figures — at least until reliable 
general-purpose voice-recognition systems are 
developed. But, good as the keyboard is for 
entering text, it’s not necessarily the best device for 
entering other types of information. If you want to 
enter urgent directional data, as in many games, a 
joystick or trackball is preferable, and a mouse, 
light-pen or touch-sensitive screen is usually the 
best means of entering positional data, as when 
making menu selections. A bar-code reader is a 
convenient method of entering long serial or code 
numbers. 





ah 


All these input devices, however, suffer from 
the same inherent flaw: they are indirect. 
Although a joystick is more convenient than a 
keyboard in game-playing (to move your 
spacecraft up, for example, you push the joystick 
handle forwards) it still represents an interruption, 

a step between what you want to happen in the 
computer and what actually happens. You think 
‘up’, mentally translate this into ‘joystick forward’ 
and then physically push the joystick. For faster 
and more direct interaction between the user and 
the computer we need to eliminate this interim 
step: why not just think ‘up’ and have the 
computer respond directly to the thought? 

Imagine being able to play a game of Defender 
just by thinking ‘up’, ‘down’, ‘turn round, ‘fire’ and 
SO on, or writing a letter by just thinking the words. 
The telepathic word processor may be some years 
away yet, but the thought-controlled Defender 
game is a reality today, made possible by a concept 
known as “mindlink’. 

In the mindlink concept, thought — or more 
accurately the physiological changes that result 
from changes in thought-patterns — is used to 
control an electronic device. This device serves as 
an interface to a computer in much the same way 
as a joystick or any other input device. Mindlink is 
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‘Mindgames 

The Mindlink concept 
eliminates the intermediate 
mechanical stage of : 


‘translating the player’s 


impulses into signals 
meaningful to the computer. 
By allowing a more direct 
relationship between user and 
machine, Mindlink offers the 
possibility of friendlier 
software and faster input 








APPLICATION / MINDLINK 





Mental Notes — 
| onan Apple computer is shown here. Similar — 
_ systems have been developed for use with the IBM 
and Commodore PC’s but development of effective 
software is likely to take some time. Roger Dilts, 
___ president of Behavioral Engineering and author of 
___ GSR software, is particularly interested in the - 


possibility of combining Mindlink with NLP (Neuro- _ 


inguistic Programming) — a branch of psychology 
that has been largely concerned with the study of — 


learning. By using the GSR technique to monitor a : 


_ user's mental state, software can a Sy 


assess : nts eriotiondl response to the 
_ an ee If the presentation is oO 
complex, the emotional tension cai 
picked up by the computer and enable the pac 
_ the ee lo be oes or the subject matter to 


































GSR: The Mindlink Principle 


The mindlink concept is based on a phenomenon 
known by three alternative names: the galvanic skin 
response (GSR), the psychogalvanic reflex (PGR) 
anc the electrodermal reflex (EDR). We have Used 
the term GSR throughout this article. 

GSR refers to changes in the electrical 
conductivity of the skin that correspond to changes 
in the emotional state of the person. 
Experimentation has shown that the more tense a 
person is, the lower the electrical resistance of their 
skin. The best-known application of GSR is in 
polygraphs, the so-called lie-detectors . 

Although the GSR phenomenon has been 
observed in both humans and animals since the 19th 
century, very little is known about its cause. The 
original theory was that the sweat produced by 
excitement or anxiety simply acts as an electrolytic 
conductor, thus decreasing the resistance of the 
skin. More recent experiments have, however, cast 
doubt on this simplistic theory. 

But, whatever the reason for the effect, GSR is 
known to be directly related to the degree of tension 
present in the sympathetic nervous system. This in 
turn is dependent on the central nervous system and 
thus on the brain — hence the possibility of 
controlling a computer by thought. Changes in the 
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A dencrstelcn of a prototype GSR lost running 


based on what is known as the ‘GSR 
phenomenon’, whereby changes in a human’s 
emotional state manifest themselves in_ the 
electrical conductivity of the skin. The user is 
connected to a resistance meter by means of 
electrodes. Signals from this meter are fed into the 
user port of a computer and these are interpreted 
and acted upon by specially written software. 
California-based company Behavioral 
Engineering has based both games and practical 
software on this technique, and among its products 
in the field is a simplified version of Defender. 
Several major computer companies are also 
known to have been working in this field for 
several years, notably Atari, but only recently have 
they met with any degree of success. 

In the conventional Defender game you control 
a spacecraft orbiting a planet. The idea is to shoot 
alien ships without being shot yourself and 
without crashing into the planet below. In the 
Behavioral Engineering version, all you control is 
the ship’s height: the difference is that you do it by 
thought! The company has designed a GSR 
interface to the Apple Ile. The user simply places 
the index and middle finger of one hand onto a 
mouse-like device that measures the resistance 
across the two fingers and feeds the resulting 
values into the computer. The software is designed 
so that an increase in current (a low resistance 
brought about by increased tension) results in the 
ship climbing while a decrease in resistance allows 
the ship to fall. The idea, of course, is to control 
these movements to align the ship with 
approaching targets. 





activity of the brain bring about changes in the state 
of the central nervous system; this produces a 
change in the state of the sympathetic nervous 
system that results in changes in Skin resistance. 
And changing an electrical current is the basis of any 
form of input device 
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The term ‘mindlink’, believed to have been 
coined by Atari, is perhaps misleading, since the 
link is with the nervous system rather than the 
mind. This is, however, a grey area: if the two are 
interdependent, does it make sense to separate 
them? Most people find that they are able to 
exercise a fair degree of control after about 20 
minutes, often without being aware of how they’re 
doing it. Some people consciously tense and relax 
their body slightly, whereas others simply think 
‘up’ or ‘down’ and let their nervous system do the 
rest. 

As well as games, mindlink has more practical 
applications. People who are completely 
paralysed still have the facility to consciously 
generate GSR effects, despite the fact that they 
have no control over their muscles. A GSR device 
has already been successfully linked to the Topo 
robot via an Apple computer, allowing a paralysed 
person to control the robot. Another interesting 
application is in space under zero gravity 
conditions. It can be extremely difficult to operate 
mechanical controls without gravity to 
counterbalance the force exerted. A GSR device 
could make an ideal substitute for many 
mechanical controls. 


MOOD-SENSING SOFTWARE 


Even more exotic applications include mood- 
sensing software. Educational software, 
particularly, could benefit from GSR feedback on 
the internal state of the user. The subject could 
wear a wristband containing the electrodes and 
allow the software to callibrate to their normal 
relaxed state. Then, if at any point in the program 
the GSR device registers a marked increase in 
tension, it can assume that the user is having 
difficulty and act accordingly. Even business 
software could detect stress in its user, and suggest 
a coffee break! 

Just how rapidly GSR technology will develop 
depends partly on the introduction of more 
accurate and faster-responding devices and partly 
on our ability to refine our interpretation of the 
effects. The former problem is that a GSR 
response typically occurs two seconds after the 
event and takes between two and 10 seconds to 
fade. Present day devices ovecome this problem to 
an extent by measuring the rate of change of 
response rather than the strength of the response 
itself, but further work is necessary. The second 
problem centres on the crude nature of the 
deductions were able to make from GSR 
feedback. We know that a rapid decrease in skin 
resistance indicates some kind of stress or tension, 
but we're not yet able to determine whether the 
tension is pleasurable or painful. 

Despite the problems, however, GSR offers 
some exciting possibilities. And Atari is not alone 
in taking those possibilities seriously. Commodore 
is reputed to have offered Behavioral Engineering 
two million dollars for exclusive rights to its GSR 
device and software. Behavioral Engineering 
declined the offer. 





THE HOME COMPUTER ADVANCED COURSE 1203 





DYNAMIC 
STRUCTURES 





As 1 we » continue to create a ‘database’, we 
move from the use of functions within 
parameters to the development of an 
‘informal’ algorithm. And since the heart of 
any database is the organisation of its files, 
we present several programs illustrating 
PASCAL’S insistence on precise programming 
techniques when dealing with files. 





We can noe onic the eediaiadi Gia our 
‘database’ (see page 1185) by thinking about a few 
essential variables and an ‘informal’ algorithm. 


VAR 
list : RecordList: 
size : Cardinal: 

BEGIN 
size = 0; { active size of the list } 
{ read the data into the list, updating size } 
{ sort size items into the correct order | 

_ {print size items of the list } 
END. 


To translate this informal algorithm into 
something more tangible, we need to express the 
three main stages of processing as calls to 
procedures (with appropriate names) and to list 
any known data that each will require in the form 
of a parameter list. When this simple step is done, 
we can then write all the procedure blocks as a 
skeleton. For example, the last statement in the 
program will become: 


Print (list, size) 


The procedure will have all the information it 
needs if we pass it the list of data values and the 
number of elements, so the heading will not need 
any VARs in this case: 


PROCEDURE Print (items : RecordList; 
high : bounds); 


We could go on to code the procedure in full, but it 
is best to leave it as a BEGIN... END ‘stub’ for now 
and deal with the other ‘level 1’ procedures. We 
must choose a name for each one, decide which 
data items need to be passed as parameters to 
which procedures, and determine whether any of 
these items need to be passed as “VAR’ (address) 
parameters. 

All the data structuring methods we have 
discussed so far have been fixed in size. This is 
specified in the TYPE definitions and therefore is 
known at compile time. PAscaL provides 
advanced data structures which can vary their size 
(and even their type within certain constraints) 
during execution of a program. The size of an 
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advanced structure is only limited by the physical 
memory or backing storage available, and the 
most familiar advanced structure is the sequential 
file. 

Like an array, each element of a file may be of 
any type, simple or structured, with the exception 
that you can’t have a file of files. Using our 
previous record type definition, we could add the 
following declarations: 


TYPE 
FileType = FILE OF data; 
VAR 
_ DataFile :FileType: 


which would enable us to create and process a file 
containing an infinite number of components, 
each one of which was a record of a name, debt 
and any other fields we wish. Just as we say read 
(symbol ), meaning read a single char from the file 
input, we can say: read ( DataFile, item ) or, write 


(DataFile, item ) and handle a whole record structure _ 


as one data object. If these files are required only 
during the execution of the program, the only 
other requirement is to open them for reading 
from or writing to with the predefined procedures 
reset and rewrite, respectively. 

Should you wish to make them permanent, 
which is more likely, then the file identifiers must 
be listed in the program header parameter list. In 
this case, for instance: 


PROGRAM DataHandler (input, output, DataFile ); 


Every time we use read or write statements, we call 
PASCAL’ predefined file I/O procedures. The only 
two files we know about so far, in fact, are the 
standard I/O devices on our computer. The file 
input is normally a keyboard and output will 
invariably be a VDU screen on microcomputer 
systems. By pretending that these devices are files, 
the handling of all I/O becomes extremely 
consistent in PASCAL. Remember that when we say 
write (N), omitting any file name, the value of N is 
printed in character form on the file output. 
Leaving a file name out in read or ReadLn 
statements defaults to the file input. Both these files 
are text files — that is to say, each ‘record’ of the file 
is a single char value. 


TEXT FILES 


Unlike other files, however, text files may have (as 
well as an end of file marker) special end of line 
markers embedded anywhere within them.These 
markers will vary with different operating systems, 
and may consist of a single control character, two 
characters (CR and LF for example) or possibly no 
characters at all, the length of each line being 








ee 





Reading From A File 


stored instead. 

In order to preserve portability, PASCAL provides 
the function EoLn ( F ) and the two predefined 
procedures ReadLn ( F ) and WriteLn ( F ) — all of 
which can only be used with files of type text. The 
EoF (F) function can, of course, be used with any 
file type. As the end of line marker may or may not 
be a single char, reading a char value when EoLn is 
true will return a Space character. Consequently, 
we should normally check with EoLn beforehand. 
As both input and output exist before and after any 
program is executed, they are permanently open, 
and do not need to be explicitly located or created. 

With files other than input and output we must 
assign them to an external system name and then 
either open them for reading with a call to the 
reset. procedure — i.e.reset ( SomefFile )—or create a 
directory entry preparatory to writing to them by 
rewrite ( AnotherFile ). A general scheme for 
processing a text file is thus simply: 


{ open the file } 


WHILE { not reached the end of the source file } DO 
WHILE { not at the end of a line } DO 
{ read a character | 
process the character | 
{ skip the end of line} 


PUT AND GET 


The procedures read and write are in fact 
implemented using file buffers and the I/O 
primitives put (for output) and get (for input from 
files). When a file is rewritten, no information is 
placed in the buffer until a write is performed. This 
actually consists of the two operations: 


F := data: 
put ( F ) 


Similarly, the statement read ( F, data ) can also be 
expressed: 


data :=F 
get ( F) 
Thus the I/O statements in our Copy procedure: 


read ( source, character ); 
write ( destination, character ) 


could equally well have been coded as: 


destination” := source’; 
put ( destination ); 
get ( source ) 


We would then not require the local char variable, 
character. A better understanding of the operation 
of ReadLn ( F ) may be obtained, perhaps, if we 
express it in terms of these primitives: 


WHILE NOT EoLn ( F) DO 
get ( F ); { throw away the rest of the line, if any } 


get (F){.. and skip the EoLn character(s) } 


Thus after a ReadLn the file buffer will always 
contain the first item on the next line to be read. 
This could be a space if EoLn ( F ) is true or be 
undefined if EoF (F) is true. It is obviously illegal to 
attempt to read from a file when EoFis true, but it is 
also an error to perform any operation, including 
testing the file buffer. This means you need to be 
careful when dealing with files other than input and 
output. But by the same token, having to be aware 
of potential error conditions such as these will 
encourage the writing of extremely robust 
software. , 

Now that we know how to ‘look ahead’ at an 
incoming data stream, we can formulate the 
SkipBlanks procedure that we postulated in the 
previous instalment. 


PROCEDURE SkipBlanks ( VAR F : text ); 


CONST 
space=; 
VAR 
done : boolean; 
BEGIN 
done := EoF (F); 
IF NOT done THEN 


done := input > space; 


WHILE NOT done DO 
BEGIN 





In A File’s Shadow 

The process of opening a file F 
inPASCAL setsupan 
associated buffer area, F , into 
which the first character from 
the file is read. When a read is 
performed, the character in the 
buffer area is assigned to a 
variable and the next character 
from the file is transferred to the . 
buffer area. If the first few 
characters of F are PENCILS, 
then, on opening the file, P will 
be read into F. Following the 
first read operation, P will be 
assigned to a PASCAL variable, 
and be replaced by E in the 
buffer, F 
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get (F); 
done := EoF ( F); 


IF NOT done THEN 
done := F > space 
— END 


END; { SkipBlanks 


Notice that this will skip all white space on a text 
file, including end of line characters. If we just wish 
to skip space on any one line, we can alter the 
conditional assignment to: | 


done := EoLn (F) OR(F > space) 


Should we subsequently wish to skip all white 
space: 


REPEAT 
SkipBlanks (F ); 


IF NOT EoF (F) THEN 
TextFound := NOT EoLn ( F ) 


UNTIL TextFound OR EoF ( F) 


With this last modification it becomes a simple 
matter to write interactive programs checking for 
null inputs. For instance: 


REPEAT 
write (‘Enter data :’); 
SkipBlanks ( input ) 


UNTIL NOT EoLn ( input ) 


This will fail 1f you happen to enter the control 
character used by the system to indicate the end of 
file, but we could always use the previous scheme 


if we wish to make our program absolutely safe. 
The procedure assign has come to be regarded as 
a ‘standard extension’ and may well be officially 
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adopted soon, along with open and seek for 
random access files. Other essential extensions in 
common use are: 


FUNCTION Fstat ( FileName ) 


which returns a boolean result — true if a file 
already exists — and a 


PROCEDURE Rename ( OldName, NewName ) 
facility. 








wee 





THE MIGHTY PEN 





Using Archive, Card Box and dBase II, we 
have illustrated thus far many of the 
fundamental concepts of database 
management. We now turn our attention to 
MicroPen, designed for the Amstrad CPC 
464, which is just one of many DBMs now 
available at relatively low cost for most 
home micro users. 





Described as a ‘database filing system for the CPC 
464’, MicroPen is published by the Amsoft 
division of Amstrad, but is the work of the 
software house, Intelligence Ireland. MicroPen 
forms part of a triptych of programs comprising a 
DBM, word processor and spreadsheet. The 
package has conceptual similarities to suites such 
as the Lotus 1-2-3 and Sord’s PIPS. The DBM 
component includes a word processor called 
Penform. This is used to create the on-screen 
format of the records to be used within a DBM file. 
The DBM itself is called, simply, Pen. 

The Amstrad version of MicroPen runs under 
CP/M-80, and therefore requires at least one 
DDI-1 disk drive. Although this might seem like 
an unfortunate extra expense, you will quickly 
realise that the speed and capacity of disks is 


OPTIONS 


_AND PRINT 


E 


essential — cassette-based DBMs can be painfully 
slow and frustrating. 

Before a database file can be created, you must 
first create the layout or format for the records that 
will go into the file. This is done by running 
Penform. Although referred to in_ the 
documentation as a word processor, this is really 
just a screen editor. That is to say, it allows 
characters to be entered or modified on the screen, 
moving the cursor around using the cursor Keys. 
Simple editing commands, such as [CTRL]Y to 
delete a line or [ESC]E to save to disk, augment the 
cursor keys. Penform is not a full word processor, 
as it cannot be used to create and edit full-length 
documents such as letters or articles. 

There are a few restrictions on how much 
information can go into a MicroPen database file. 
A record (called a ‘layout’ in the documentation) 
may have up to 100 fields in it, but no record may 
contain more than 1,024 characters. Theoretically, 
a file may contain up to 32,750 records, but in 
practice such a large number of records is not 
feasible on a floppy disk-based system. The full 
complement of 32,750 records, each containing 
the maximum allowable 1,024 characters, would 
require more than 33 megabytes of disk storage 
just for the raw data alone (assuming that data- 


SUB OPTIONS 
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Plan Of Action 

These are the different options 
and operator procedures 
available from MicroPen’s Main 
Menu. DBM’s with their own in- 
built programming language, 


- such as dBase Il, enable you to 


construct similar procedural 
sequences for your own 
requirements 





compression techniques are not used). 

An unusual feature of the MicroPen DBM is 
that each field in a record has to be given a unique 
identifier on-screen. These identifiers are called 
‘field markers’ and may be any printable character 
except the square bracket, which is unavailable 
because it has a special role as a field delimiter. 

If we were using MicroPen as the DBM for our 
PARTS database, a record layout created by 
Penform might look like this: 


Maker’s Part Number: [A 


Our Part Number: [B | 
Price: (0) No. In Stock: [D l 
Description: [E ] 
Supplier:  [F | 
Supplier's Phone Number: [G 

Who To Speak To: + [H ] 


Having created a format such as this, it is saved to 
disk using a filename such as PARTS.INP (the .INP 


‘extension’ to the filename is required by the Pen 


DBM program). 
RUNNING PEN 


When it is run, Pen displays a prompt on the screen 
that asks which database file is to be used. ‘To use 
our inventory database, we would answer PARTS 
(the .INP extension to the filename is not required). 
Pen then displays a menu, known as the ‘main 
menu’, which provides five options: 


Database: PARTS, per record 328, records on file 0. 


O=Exit, 1=Enter, 2=Recall, 3=Recall&Print, 4=Index, 
5=Organise 


Option 1 is needed to enter records. The top line — 
the statistics line — shows that there are 382 
characters per record, but no records (as yet) are in 
the file. Selecting option 1 displays the record 
format on the screen with instructions. In our 
example, the screen would look like this: 


Press {ESC} when data entry completed for record 1 
Press °C to clear field 


Maker’s Part Number: 

Our Part Number: 

Price: 

Description: 

Supplier: 

Supplier's Phone Number: 
Who To Speak To: 


The data is typed in the usual way. After the data 
for a field has been input, pressing ENTER ends 
entry for that field and moves the cursor to the 
next field. Errors within a field can be corrected by 
using the Delete key. When the entire record has 
been entered correctly, a sub-menu will be 
displayed using the Escape key: 

O=Exit 

1=Continue 

2=Write Record to File 


Option 2 writes the record to disk and displays 
the format for the next record. 


No. In Stock: 
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The main menu option 2 allows records to be 
accessed, or recalled. This option brings up 
another sub-menu: 


O=Exit 

1=Record number 
2=search 

3=List all on file 


Options 0 and 1 are fairly self-explanatory; option 
1 allows you to specify and display a relevant 
record — it assumes, however, that you know the 
number of the record you want, although it is 
unlikely that you will remember this if there are 
many records in the file. Option 2 allows various 
search parameters to be specified so that a certain 
record can be located that conforms to the 
specification. The search sub-menu is: 


Recall by: 


Press Escape when search profile complete. To set 
Search mode: 

*Q=Contains, W=Not contains, E=Equals, R=Not 
equals, * T=Greater, “Y=Less 


You will already have noticed that there is a great 
inconsistency in the commands and menu options 
for the various parts of the package: sometimes the 
Escape key must be pressed, sometimes a CTRL - 
letter combination, sometimes a menu number. 
The CTRL - letter combinations seldom have real 
mnemonic values — *E to find a record with 
matching fields during a search, * Q to specify 
Contains and so on. Be that as it may, the ‘search’ 
options allow reasonable flexibility in specifying 
the records to be searched for. 

Having given the parameters that define the 
record required, CTRL - letter combinations allow 
records to be located that contain the specified 
data; do not contain the specified data; have 
matching field data; do not have matching field 
data; or have a field value less than the specified 
field value. If you wanted, for example, to locate 
records of parts with a PRICE less than 37.50, this 
could easily be achieved. 

MicroPen has the useful facility of being able to 
create an index of all the entries in a database file. 
Indexing is done by field, and the maximum 
number of records must also be known. The field 
is specified by its identifier, not by our name for the 
field. To get an index of Our Part Number, and 
assuming that there were 500 records in the file, we 
would specify B=#500 (B being the identifier for 
the Our Part Number field). 

MicroPen offers reasonably advanced search 
and indexing capabilities and, at around £50, will 
be affordable to many home computer users. It 
does not, however, offer the advantage of a built- 
in programming language, such as those included 
with Archive and dBase II. Although dBase II is an 
expensive package designed for expensive 
computers, Archive comes ‘free’ with the Sinclair 
QL at an all-inclusive price comparable to an 
Amstrad CPC 464 plus disk drive and MicroPen 
software. These are the kinds of considerations 
you should bear in mind before buying a computer 
system and the DBM software to go with it. 

















AMSTRAD SPIN-OFF 





The Amstrad computer’s n 
and excellent BAsic ensured its popularity 
among less experienced users, but its lack of 
a fast storage capability has restricted its 
appeal to the lower end of the market. We 
examine Amstrad’s DDI-1 disk drive 
package, which provides an economic 
upgrade for the machine 








The concept of the computer as another article of 
home electronics like a television or hi-fi, 
permanently set up in a corner of the room rather 
than having to be assembled and connected to 
other components each time it is to be used, 
obviously struck a chord with enthusiasts. There is 
also the bonus of avoiding battles over who uses 
the television. 

The Amstrad is highly popular with home 
users, but it has had one major drawback: despite 
the fact that the company built a cassette drive into 


the machine, the computer lacked a fast storage 


capability. A disk drive was promised at the 
launch, prompting many people to buy the 
computer with the expectation that this would 
soon be available. However, shipments did not 
appear until the following year and the device is 
becoming widely available through retail outlets. 

The disk drive package consists of the disk 
drive, an interface (allowing the machine to be 
connected to the floppy disk port at the rear of the 
computer), a system disk and a manual. The other 
end of the interface cable slides into the 34-way 
connector on the back of the disk drive. 

The disk drive itself uses the Hitachi-standard 
3in disks. This seems an odd choice, for it is Sony 
rather than Hitachi that appears to be winning the 
battle to capture the microfloppy market. The 
Sony 33in format looks like becoming the standard 
as an increasing number of manufacturers — 
including Apple, Apricot and recently Acorn with 
its Electron — adopt Sony disks for their drives. 
Other than Amstrad, no major computer 
manufacturer seems to have opted for Hitachi 
disks. | 

Inside the drive, two clearly visible motors 
control the disk rotation and the single read/write 
head. At the back is the on-board power supply, 
shielded from the disk drive mechanism by a metal 
plate to guard against excess heat and stray 
magnetic fields. On the back of the casing above 
the interface port is an on/off switch. 

The disks used by the Amstrad are similar in 
concept to their Sony counterparts, although they 
look very different. The Amstrad disks measure 
100 by 80 by 4mm and, like the Sony disks, are 





cased in plastic and have a metal plate over the 
read/write window to protect the disk from 
fingermarks. This is slid back when placed in the 
drive. The Amstrad disks, however, have their 
shields on the inside of the metal casing, whereas 
Sony has placed them on the outside. 

The drive worked quickly and reliably and had 
no trouble finding files and loading them within a 


few seconds, but it seemed noisier than Sony’s. 


product. It was, however, quieter than the average 
5zin floppy disk drive. 


SYSTEM DISK 
Contained within the system disk are three basic 
utilities: AmsDOS, Amstrad’s own disk operating 
system, and two utilities from Digital Research — 
the widely used CP/M disk operating system and 
Dr LoGo, a popular implementation of the turtle 
graphics and learning language becoming more 
widespread on micros and showing signs of 
displacing BAsic as the primary language on home 
computers. | 7 

Turning first to AmsDOS, this is perhaps the 
weakest of the three utilities provided. To be able 
to run AmsDOS, you first have to LOAD CP/M. 
This may seem a trifle strange, but the result is that 
AmsDOS appears to use no more memory than 
CP/M alone and so CP/M must be discarded 
once it has loaded AmsDOS. Unlike CP/M, 
which is a self-contained operating system, 
AmsDOS merely adds disk operating commands 


Moving Up Market 
The Amstrad DDI-1 disk drive 
enables users to upgrade their 
systems to the specifications 
required of a ‘serious’ 
microcomputer. With the 
addition of the three progams 
bundled with the disk drive — 
CP/M, AmsDOS and Dr LOGO 
— the Amstrad CPC 464 now 
has a much greater number of 
applications. The drive connects 
with the computer, via the 
interface cable that is provided, 
through the floppy disk interface 
port 
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to the bar symbol character I (Shift @); for 
example: I DRIVE and I DIR. 

The method of manipulating disk files from 
AmsDOS is one of the most peculiar systems seen 
on any home micro. In order to, say, ERAse a file, 
you must first assign the filename to a string; only 
then can you delete the file by erasing the string. 
Thus, to erase the file INVOICE.SSS, the sequence of 
commands is: | 


AS=“INVOICE.SS$” 
| ERA,aAS 


This method becomes even more complicated 
when RENaming a file, since two different files (old 
name and new name) have to be assigned to 
strings that can then be manipulated. Many users 
may find it easier to boot CP/M for such 
procedures when the commands can be carried 
out on a single line. However, CP/M has its own 
difficulties. Primarily, there are no facilities for 
running Amstrad Basic under CP/M, so you will 
be forced to use AmsDOS if you want to program 
the disk drive system in BASIC. 

The CP/M operating system on the system disk 
is the 2.2 version that has been applied on a vast 
number of eight-bit business machines in the last 
decade. Along with the CP/M itself, the usual 
‘transient commands are provided with the 
system. Transient commands are those held 
permanently on disk and loaded into the 
computer’s memory only when required; they are 
then discarded by the CP/M operating system. 
The trouble here is that to be able to use a large 
number of commands in CP/M (such as PIP, 
which transfers a file from one peripheral device to 
another) the operating system really requires two 
disk drives to be fitted to the computer — one to 
hold the systems disk so that the transient 
commands can be accessed quickly and simply, 
and another to hold the files. 

Apart from the necessity in using the CP/M to 
continually swap the data and systems disk in and 
out of a single drive, many commands simply 
make no provision for the user having only a single 
drive available and expect to be able to transfer the 
files from one drive to another. To counter this, 
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Amstrad has included extra transient commands 
for single drive transfer of files. FILECOPY provides 
prompts enabling you to exchange disks when 
transferring a file and, similarly, DISCCOPY copies 
an entire disk. Still, you need to buy two disk 
drives to take full advantage of the system. 

The cynical view is that this is a clever ploy by 
Amstrad to force customers to buy two disk drives 
rather than one. However, a more charitable 
explanation is that the provision of CP/M has 
more to do with Amstrad’s long term strategy. The 
philosophy behind the company’s range of 
computers is not to produce leading-edge 
technology products, but to provide tried and 
tested equipment that can be used for a wide range 
of applications. Hence the company’s decision to 
opt for the Z80 processor when most other 
manufacturers are scrambling to produce 16-bit 
machines. The use of CP/M fits in well with this 
since, although not the most user-friendly of disk 


operating systems, it is adaptable and there are 


thousands of programmers throughout the world 
with experience of writing software to be run 
under the system. 

Despite the problems of using CP/M with only 
a single drive available, Amstrad is to be 
congratulated on providing a full implementation 
of such a powerful disk operating system on a 
home micro. Only a few years ago a computer with 
CP/M capability would have cost about £2,000, 
and now Amstrad is providing the same system for 
less than half that amount. 


DIGITAL RESEARCH’S LOGO 


Dr Loco is a version of the popular language used 
in many educational establishments. The 
language runs under CP/M, which therefore has 
to be loaded before you can load Loco, and Dr 
LOGO can take advantage of CP/M’s extended 
disk operating facilities. For example, CP/M 
allows the use of ‘wildcards’, which means that 
Loco files can be called without a full name being 
typed in; so by typing a partial name, the language 
will call all the files fitting that partial description. 

Loco allows use of the sound and graphics 
capabilities of the Amstrad and implementation 


CF 
gon net ayy 
fs 


can 












will be familiar to those who followed our LOGO 
series (beginning on page 506). Provision is also 
made for the language to be operated from a 
joystick and fire buttons, so it is possible to write 
games in Loco that can be easily interfaced to 
joystick control. 

Although the implementation of Dr Loco is 
very good and compares well with many other 
versions of the language, there is some doubt as to 
how well it fares under the hardware limitations. 
For example, a tessellation program (one that 
requires the same design to be repeated a number 
of times in order to fill the screen) that runs 
perfectly well on the Commodore 64, generated a 
‘not enough space on stack’ message on the 
Amstrad, indicating that perhaps the language 
does not fit as comfortably as it could. Apart from 
this, Dr Loco is fast and friendly and is an ideal 
introduction to the language. 


As with all disk systems for home micros, the 
popularity of the system, at least initially, will stand 
or fall on software support. Amstrad has already 
made a number of utilities for the disk drive, most 
of which seem to be aimed at the more ‘serious’ 
home enthusiast. These packages include a 
database, a word processor and additional 
languages such as PASCAL. 

In launching the disk drive for its machine, 
Amstrad has taken an apparently successful step 
towards making its computer a more up-market 
machine without imposing a price normally 
associated with such systems. The addition of a 
disk drive makes the computer even more 
competitive and illustrates Amstrad’s intentions to 
broaden the scope of the machine beyond the 
fading games market. It seems a pity that some of 
the utilities were not made a little friendlier, as the 
majority of customers will be new to disk drives. 


PRICE 

£199 inc VA] 
DIMENSIONS 
280x 105x/5mm 


CAPACITY 
Systems disk: 169K: data disk: 
178K 


INTERFACES 


single 34-way parallel 
interface. | he interface cable 
accommodates two disk 


drives 

DOCUMENTATION 

The manual provided is patchy 
and iLis sometimes difficult to 
locate the information you 
require 

STRENGTHS 

The provision of CP/M and Dr 
LOGO upgrades the Amstrad 
computer 10 a very powerlul 


machine 


WEAKNESSES 

AmsDOS is not very well 
implemented and users with a 
Single drive may lind that 
neither AmsDOS nor CP/M is 
entirely Suited to their needs 
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see whether there are guns aboard. If the value of 
OA(2) is 0 or -999, there are no guns and Kis set to 4. 
If there are guns in the ship, the variable SS is set to 
IN SPITE OF YOUR GUNS. If K has been set to 4, SS is A storm, handled by the subroutine at 7000, 
changed to YOU HAVE NO GUNS. represents the fifth possible major event. It blows 
Another loop is set up, between lines 6836 and _ the ship off-course and increases the length of the 
6845, to delete the appropriate number of crew _ journey. If there is a navigator in the crew, the ship 
members, and line 6835 sets X equalto0tokeepa will quickly be set on the correct course. If not, the 
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| journey will take longer. This subroutine is similar number, and if less than .25, goes to the next 
in structure to the ‘broken rudder’ subroutine, provision. (There is a one-in-four chance of not 
and, in fact, uses part of its coding. obtaining each provision type.) Line 7115 
| The pee checks whether the storm has_ generates a random number between 5 and 14, 
ed and, if not, sets the value of M(5) stored in X. This amount is printed by 7120, 
edinthevalue followed by the units of that particular provision, 
whether in kilos or barrels. If a provision had been 
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pent 


visions-Wil btained:and thé p ayer will be 
minded of ooting. The program is sent to 
fine 7130, otis increments the journey length. 
| If the bird was not shot, a loop, from 1 to 4 for 
| each provision type, is set up at line 7110 to collect 
the extra provisions; the amount of supplies is 
| selected at random. Line 7112 generates a random 
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PROGRAMMING PROJECTS /SIMULATION GAME 





Module Nine: Other Major Events RE ok 


Initialise Flags 745@ REM ISLAND 
ba a 4)= n 
| 48 At="N"  BS=" tN" 7455 IFM(4)=1THENRETURN 


7866 PRINTCHREé(147> 
“865 MC é9=1 


Pirates Contingency Routine 7070 S$="YOUR CHARTS SHOW AN ISLAND*":GOSUB9190 
4800 REM PIRATES 7071 S$="WHERE YOU MAY BE ABLE TOx":GOSUB91a¢ 
4885 LFM(2)=1 THENRETURM 7072 S$="RE-STOCK YOUR PROVISIONS*" :GOSUB9108 
(6810 x= 7073 S$="BUT IF YOU GO THERE*" :GOSUB9106 

6812 FORT=1TO14 7074 S$="IT WILL ADD TIME TO YOUR JOURNEY*" :GOSLBS 
6814 1ETS(T,2)-O0RTS(T , 2)=-9 99 THEN 1 iaa 

6815 NEXT 7475 PRINT: GOSUB9204 

68146 I1FX=16 THEN RETURN 7080 S$="D0 YOU WANT TO GO THERE*" :GOSUB9100 
6818 MCS)=1 7082 INPUTI¢:1$=LEFTS(I¢,1) 

6820 PRINTCHR$(147) 7084 LFI$<>"¥"ANDI$<>"N"THEN7G82 

4822 S$=" PIRATES ATTACK THE SHIP! *":GOSUB9iga 7896 PRINT:GOSUB9z00 

6824 PRINT: GOSUB92a4 7090 1F1$="N"THEN7145 

6625 K=2 7109 S$="YOU REACH THE ISLAND*" :GOSUBS190 

4826 IFOAC2)=G0R0A( 2)=-999THENK=4 7165 S$="AND OBTAIN: *" :GOSUBS1a8 

6828 S$="IN SPITE OF YOUR GUNS#" 7106 LFEBS="N"THEN?1 14 

4838 LFK=4THENS$="YOUl HAVE NO GUNS*" 7187 PRINT: GOSUIB92a0 

4832 GOSUB?1a0 7188 PRINT"NOTHING! ":GOSUBsz2068 

6635 x=6 7109 S#="(REMEMBER THE ALBATROSS!) ":GOSUB919a:GOTO 
68346 FORT=1TOLS 7130 

6838 IFTS(T, 2)=GORTS(T , 2)=-999THENSS45 7110 FORT=1T04 

6840 X=X+1:7S(T,2)=-999 7112 IFRND(1)<.25THEN7129 

6842 1FX=KTHENT=1 4 7115 X=INTCRND(1)*10045 

6845 NEXT Fi20 PRINTX:US¢(T)3;"S OF" ;Pé¢T) 

6858 PRINTX; F7i22 LEPACT)=-999THENPACT)=0 

6855 S$="0F THE CREW 1S KILLED" 9125 PACTI=PACTI+x 

48546 1FX>1THENS$="GF THE CREW ARE KILLED" 5159 NEXT 

4849 GOSUBS1ea 7130 S$="BUT THE JOURNEY WILL NOW TAKE*" :GOSUB91a0 
4865 PRINT: GOSUB92a8 

6890 S$=K$:GOSUB9140 7135 X=INTCRND(1)*29+1 

4895 GETI$:1F1$=""THEN6S95 F189 PRINTX::S$="WEEKS LONGER*" :GOSUB91a0 

6899 RETURN : 7140 EW=EW+x 

7145 PRINT: GOSUBSZ00 
Rudder Contingency Routine | ose See ete . 
cea REM RUDDER 7155 GETI$¢:1FI¢=""THEN7155 


6905 IFM¢4)=1THENRETURN ake 


6910 PRINTCHR#(1473 

6915 MC4o=1 

6928 S¢="TROUBLE WITH THE RUDDER! *" :GOSUE9104 
6925 PRINT: GOSUB92406 

4928 xX=4 

693G FORT=1TO16 

4935 LFTSC(T,1)=SANDTSC(T , 234 3GANDTSCT 29 63-999 
THENX =1:T=16 

4938 NEXT 

4940 S$="GLTHOUGH YOU HAVE & MECHANICS" 

6945 LFX=4THENS$="YOU HAVE NO MECHANIC AND®" 
4950 GOSUBS1aq 

6955 S$="OUR JOURNEY WILL TAKE*" :GOSUB?144 
6968 PRINTX;"WEEKS LONGER" 

6965 EWHEW+X | 

6967 PRINT:GOSUB92aa 

6969 S$=K$:GOSUB9108 

4970 GETI$:IF1$=""THENS?78 

6975 RETURN 


Storm Contingency Routine 


“866 REM STORM 

7065 IFM¢5)=1THENRETURN 

“@16 PRINTCHRE? 147) 

“O15 MCS3=1 

“626 St="OU ARE BLOWN OFF COURSE*" :GOSUB?146 
7622 St="IN A STORM! *" :GOSUBS1 46 

“625 PRINT :GOSUBS 244 

7028 X=2 

“7636 FORT=1TO1¢6 

7035 IFTSCT,1°=4ANDTS(T,2)<36ANDTS¢T , 2) <>-999THENX 
=1:T=16 

7438 MEXT 

7846 S#="ALTHOUGH YOU HAVE A NAVIGATORS" 
7645 I[FX=2THENS#="YOU HAVE NO HWAVIGATOR AND#" 
769% GOTOé97S6 
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OUTPUT DEVICE 


This is any piece of machinery that allows a 
computer to interface with the ‘outside world’— 
without output devices, the processed information 
within the computer could not be accessed. Their 
most common applications are to enable users to 
understand the results of the machine's 
calculations, although this is not their sole 
function. There are a large number of output 
devices available for the microcomputer at 
present, the most common of which are cathode- 
ray tubes — both monitors (see page 1120) and 
television screens — and printers. However, 
advancing technology and the increasing use of 
computers in a wide number of new applications 
means that other devices are continually being 
developed. For example, computer-controlled 
robots are becoming increasingly common in 
industrial environments. Looking further into the 
future, many experts are predicting the next major 
development in output devices to be speech 
synthesis, which will allow a apie to talk 
directly to the user. 


OVERFLOW 


This occurs when a resulting number after a 
function has been performed exceeds the memory 
space that has been set aside to store it. Overflow 
also refers to the amount by which the number has 
exceeded this space. In computing, this event will 
usually generate an error or the overflow number 
will be ignored. In either case, it is obvious that 
overflow should be avoided wherever possible. 


PACKING 


Packing is a process in which data is compressed 
into as small a memory space as possible in order 
to conserve memory. There are probably as many 
ways of achieving this as there are programmers, 
but the various systems fall into a few main 
categories. The most commonly used method is to 
store several bytes of data into a single computer 
word (two or four bytes). Other methods include 
‘keyword tokenisation’, Boolean assignment of 
variables or ‘array packing’. Often, however, 
packing will cause a subsequent loss in the speed of 
program execution. For example, in array packing 
(a feature built into the PASCAL programming 
language), the computer will require time to 
extract the necessary data from the pack. 


PAGE 


When we wish to find a reference in a book, rather 
than looking through a whole volume from 
beginning to end, we will most likely look in the 
index and discover on which page the reference is. 
In searching through a computer’s memory, the 
same concept is used, and the procedure is 
referred to as ‘paging’ the memory. 

In eight-bit computers a page consists of 256 
bytes of information (the maximum number that 
can be addressed by a single byte). The machine's 
memory is divided into a number of pages, so 
when we wish to access data held at a particular 


location, we will instruct the computer to look ata 
particular page rather than having it start at the 
beginning of memory and look through all the 
addresses in order to find the correct one. From 
there it has only that one page’s 256 bytes to search 
through. 

The concept of ‘paging’ becomes very 
important when addressing bytes of memory in 
Assembly language. For simple calculations and 
other ‘scratchpad’ information, it is usual to use 
‘zero page’, as this requires a single-byte address, 
and therefore requires less time to access the 
required data. However, for information above 
zero page, two bytes of information are required to 
obtain the address; one to specify the page and one 
to specify the location on that page. 


PAGE PRINTER 


A page printer is a device that prints pages of 
information in a single action, rather like a 
conventional printing press. This is in contrast to a 
line printer, which prints individual characters one 
after another. Obviously, this method of printing is 
considerably faster, and because of the way page 
printers act, their mechanism is somewhat 
different from the more traditional printers. To 
begin with, it is the paper that moves rather than 
the print head, and because of the speed at which 
print has to be transferred to the page, the normal 
impact printing methods are unsuitable. Hence, 
most page printers use electrostatic (see page 528) 


or laser (see page 948) technology to print. 


characters. 








Over To You 

Output devices are generally 
peripherals that display 
computer data in ways that can 
be easily understood. The - 
printer/plotters shown here are 
typical output devices. Digital 
data from the computer is 
decoded within the device and 
then translated into pen 
movements to draw pictures and 
print words on paper 
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In the previous two sections of Workshop we 
presented machine code and BASIC programs 
to control movement sequences of the 
Workshop robot arm for the BBC Micro 
and Commodore 64. We now look at a 
Similiar program for the Spectrum that 
allows the arm to be controlled via the 
interface built earlier in the course. 





The software required to control the robot arm 
must be based in machine code, as the digital servo 
motors used require regular pulses every one- 
fiftieth of a second. Such speeds are effectively 
beyond the reach of a Basic program. Like the 
Commodore and BBC Micro versions, this 
machine code is executed on an interrupt basis, 
but it differs significantly because the Spectrum 


uses a Z80 processor rather than the 65XX series 
used by the other two machines. 


The best way to handle interrupts in Z80 
machine code is to use IM 2 mode interrupts. In 
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simple terms, when this interrupt mode is set and 
an interrupt is generated to update the screen 


display (fortunately, around every one-fiftieth ofa 
second), the processor gets the start address of the 
interrupt code from two sources. The hi-byte of 
the address is held in the I register and the lo-byte is 
taken from the state of the data bus when the 
interrupt occurred. 


This system is designed for communication 
with peripherals attached to the data bus that can 


control the value held on the bus. However, in our 
application, we do not know the state of the data 


bus and so we have to accommodate all 256 
possibilities. The program therefore sets up a page 


of memory to hold the real start address of our 
program. Filling a page with #FBs and pointing to 
the page by setting the I register causes an IM 2 
interrupt to start executing code at location #FBFB. 
(This technique will be more fully described in a 
forthcoming Machine Code series on the 


pectrum operating system. ) 
The rest of the machine code uses the same 


principles of operation as the 65XX versions 
described previously, outputting a stream of pulses 
to I/O port 31, the port mapped into by our 
interface. The Basic control program also follows 
along similar lines to those developed for the BBC 
Micro and Commodore 64, allowing sequences to 
be programmed from the keyboard and replayed 
later. 








i 
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First raster interrupt causes 
switch to high resolution 
mode 





Second raster interrupt 
occurs, causing switch back 
to text mode 


_ Both Sides Of The Story 

Many commercial adventure 
games written for the 
Commodore 64 use raster 
interrupt techniques to produce 
high resolution pictures and text 
simultaneously. Spiderman by 
Scott Adams, shown here, uses 
the top third of the screen to 
display a location in the game; 
the remaining two-thirds are 
used for a description of the 
scene in the normal text display 
mode. The TV raster scan is 
programmed to generate two 
interrupts each time the screen 
is scanned: the first at the top of 
the screen and the other about 
one-third of the way down. An 
interrupt routine is called each 
time a raster interrupt occurs 
causing the display to flip 
between the high resolution and 
text modes. 


DIMENSION GRAPHICS 





SPLITTING 
IMAGE 


The second part of our investigation of 
Commodore 64 graphics considers how the 
VIC-II chip borrows time from the main 
6510 processor to create the video display. 
We provide a program that allows high- 
resolution graphics to be _ displayed 
simultaneously on a split screen — a 
technique often used in adventure games to 
e pictures and words simultaneously . 





To display video data, the VIC-II chip must read 
from memory. This is accomplished by allowing 
the VIC-II access to some (but not all) of the lines 
on the address bus, and all the lines on the data 
bus. The process by which the VIC-II reads ROM 
or RAM shared with the 6510 is called direct 
memory access (DMA). Ideally, the VIC-II would 
be using the address or data lines at times when the 
6510 does not need them, in which case the action 
of the two processors would be ‘transparent’ to 
one another. Unfortunately, the 6510 is a rather 
simple processor with very few internal registers 
and no 6510 instruction takes more than seven 
clock cycles (most take only three or four). 

Since the VIC-II must read rather a lot of data, 
especially when displaying several sprites, there is 
not enough time available for it to operate in a 
transparent fashion. Because of this, the VIC-II 
has a special control line, called the bus available 
(BA) line, which it can use to send a ‘hold off’ 
signal to the 6510. This enables the VIC-II to 
reserve as much time as it needs to read the video 
data. 

When the BA line is set low it indicates 
that the video chip will require some time from the 
6510. The other chip is then given just enough time 
to finish its current instruction before VIC-II pulls 
down the address enable control (AEC) line and 
ruthlessly disables the 6510’s address bus drivers. 
This is rather like zapping the 6510 with a phaser 
gun set to stun — it is quite unaware that it is put 
out of the game. 

The amount of time stolen from the 6510 by the 
VIC-II chip is quite significant. For example, the 
character pointer addresses must be fetched after 
every eighth raster line displayed on the screen 
(since characters have eight rows of pixels), and 
each line requires 40 consecutive accesses to fetch 
the video memory pointers (there are 40 
characters per screen row). In the PAL system 
(used in Britain), the video chip refreshes every 
other line on the 625 raster lines on the television 
screen roughly 25 times a second; the American 
NTSC system uses 524 lines, and refreshes these 
30 times a second. This adds up to a significant 
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amount of time. In fact, a little arithmetic shows 
that the net effect is to ‘slow up’ the 6510 by as 
much as 15 to 20 per cent. 

The DMAs have no apparent effect on the 
internal working of the machine. However, where 
real time I/O is concerned, these unpredictable 
‘absences’ of the 6510 may be a problem — for 
example, in the operation of the tape cassette. In 
such cases it may be necessary to blank the screen 
(using POKE 532651) during the I/O, and re- 
enable it (using POKE 53265,27) after the I/O is 
finished. Whether or not the VIC-II’s use of direct 
memory access is a problem during I/O will 
depend on the external device and the method 
used to communicate with it. In many instances, 
such as a disk access, screen blanking will not be 
necessary. 


SPLITTING THE SCREEN 


An interesting feature of the Commodore 64 is 


that, by very careful programming, one can have 


the visible screen split between high- and low- 
resolution modes. This makes it possible, for 
example, to display a high-resolution graph or 
picture while at the same time printing text or 
engaging in some user interaction in the low- © 
resolution portion of the screen. Characters 

cannot be easily printed directly on the high- 

resolution screen. 

The Splitscreen program that we provide here 
demonstrates several of the points discussed. A 
small high-resolution screen is set up behind the 
BASIC interpreter ROM _ and __ displayed 
continuously in the top third of the visible screen. 
At the same time, the lower two-thirds remain in 
normal low resolution mode. 

On page 1138 we illustrated the use of RAM 
vectors on the Commodore 64. We showed how 
changing the value of a two-byte pointer allowed 
us to divert an operating system routine along 
some code of our own. To get a split screen we 
shall divert the IRQ routine, but in a |subtle way. 

There are several ways that an IRQ to the 6510 
can be triggered. The usual way is that one of the 
CIA timers sets a bit in the interrupt flag register 
(IFR), at address 53273 ($D019), every one-sixtieth 
of a second. This causes the Commodore 64 to 
execute the IRQ service routine, which — among 
other things — scans the matrix of keyboard 
switches to see if a key is being pressed. Bits in the 
IFR are also set to one by the VIC-II chip if certain 
events occur, such as when two sprites collide or if 
the raster count reaches a pre-set value. There is 
another register, the interrupt enable register 
(IER), at address 53274 (SD01A), which acts as an 
enabling switch to the 6510 IRQ line. If 
corresponding bits in the IER are set by the 
programmer, then bits set in the IFR will trigger a 
6510 IRQ. 

The general idea of the Splitscreen program is 
as follows: 


1) When a raster interrupt occurs at the top of the 
screen, set the bit map mode, and then set up a 

















raster interrupt half way down the screen. Return 
from interrupt (RT]). 

2) On being interrupted half way down the screen, 
switch back to low-resolution mode and then set 
up the next raster interrupt to occur at the top of 
the screen (followed by another return). 


Note one rather odd feature of this arrangement: 
part of the normal screen memory corresponding 
to the top third of the screen is being used for 
colour information for the high-resolution screen 
— the remaining two-thirds being used for 
character data in the normal way. 

However, there is one snag with this program. 
The raster interrupts will occur about every one- 
fiftieth of a second and must be serviced 
immediately, as otherwise the raster beam will 
have moved on, displaying the wrong data. Now, 
in the normal course of events, the IRQ service 
routine will be triggered every one-sixtieth of a 
second. The service routine is quite long and, 
should it occur just before the raster interrupt, 
there will be a delay before getting around to our 
Splitscreen raster wedge. This must be avoided at 
all costs, or else the screen will flicker at the 
boundary of the high- and low-resolution modes. 


The solution to this problem is to force the IRQ 
service routine to occur immediately after the 
raster wedge code. This is done by turning off the 
usual one-sixtieth of a second timer, thereby 
disabling the usual IRQ trigger, and jumping to the 
IRQ service routine after executing the raster 
wedge. This forces the two pieces of code to be 
executed in synchronous relation to one another. 
Of course, it also means that the keyboard will be 
scanned marginally less frequently — this has the 
useful side-effect of making Basic run slightly 
faster, but otherwise does no harm. 

Finally, we have put the high-resolution screen 
behind the Basic interpreter ROM. This makes 
plotting to it a bit tricky in BASIC, since the language 
can’t read the RAM area behind the Basic ROM, 
and we cannot perform the necessary AND or OR 
operations to set individual pixels. However, a 
POKE will pass through the Basic ROM to the RAM 
behind, so we can do simple plotting from Basic. In 
pure machine code programs, however, we don’t 
need the interpreter ROM — it is just eight Kbytes 
of wasted space — so we blank it out. A few simple 
amendments to the source listing will allow you to 
relocate the high-resolution screen so that it can be 
used more easily from BASIC. 
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Nothing’s Impossible 

The object of Impossible 
Mission is to travel via the lifts 
and corridors to the various 
rooms within the evil scientist's 
lair. Once you have entered the 
rooms you must, while avoiding 
_ the robots, search among the 
pieces of furniture for parts of 
the password, which will 
eventually enable you to enter 
Professor Atombender’s 
laboratory. Occasionally you 
may also turn up ‘snoozers, 
which are passwords that 
temporarily switch off the robots 
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In a race against time, you find yourself 
penetrating the depths of the evil Elvin’s 
fortress, collecting passwords to a valued 
code. Impossible Mission puts you in this 
unenviable but highly enjoyable position 
with excellent graphics and speech synthesis 
in a new ‘platform’ game from Epyx. 


One of the most popular types of games program 
is the platform game. In this type, the player ( as 
the hero) must obtain articles that are positioned 
on platforms within the various screens. The hero 
usually enters the screen in one of the bottom 
corners and must reach the platforms by a series of 
lifts, ladders and trampolines (or whatever else the 
programmer has provided). Often, vital articles 
such as important treasure or keys will be placed at 
a particularly awkward position leading to 
considerable thought concerning how best to get 
there. 7 

Games such as these are further complicated by 
aliens or other dangerous graphics figures that 
have to be avoided, since touching them usually 
proves fatal. These graphics are either static, or 
else they move along preset patterns. Futhermore, 
many of these sprites have a ‘fire’ capability. 
Depending on the intentions of the programmer, 
movements of these enemies can be more or less 
intelligent. Many will move back and forth along a 
single path whereas others may be programmed to 
‘home in’ on the hero, cutting down your freedom 
of action. 
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To the programmer, platform games have 
several advantages. Primary among these is the 
relative lack of coding that is required. Once the 
programmer has defined the graphic design of the 
hero, guardians, treasure, platforms, ladders and 
lifts, all the different ‘rooms’ can be programmed 
merely by repositioning the various elements. This 
obviously saves a great deal of space, which can be 
used to enhance the detail of the game or increase 
the number of rooms. Additional space can be 
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A 
Room Of Ro bots 


IPHER CHASE 








saved because each of the platforms does not have 
to be stored separately. The programmer has only 
to store the graphic design and listings, and the 
length of each of the platforms can be stored 
separately. 

Impossible Mission takes full advantage of the 
platform game’s ability to implement code in this 
way. The object of the game is to find the various 
pieces of a code — hidden in pieces of furniture in 
32 rooms — which enables the player to break into 
the stronghold of the evil scientist, Elvin. The 
pieces of furniture are guarded by robots and 
occasionally by a large black ball. Also contained 
in some of the pieces of furniture are special 
passwords that, once obtained, enable the player 
to reset lifts within rooms and to temporarily 
switch off the robots so that they can be passed by 
in safety. These passwords are entered via the 
computer terminals placed in each room. The 
player moves from room to room via a lift and 
through a series of corridors. At the bottom left- 
hand corner of the screen is a map showing which 
rooms have been entered so far and the player’s 
current position. 

Passwords can also be obtained from code 
rooms. To receive a password, the room emits a 
number of notes of varying pitch, and the player 
has to place them in ascending order. The more 
passwords one attempts to obtain, the larger the 
number of notes that are played. In this respect, 
Impossible Mission is a standard platform game. 
Unlike most platform games, the player does not 
have a set number of ‘lives’ but, rather, each time 
the agent is ‘killed’ the player incurs a time penalty. 

The memory space saved by the programmers 
is put to excellent use here. The most notable 
feature of this is the speech synthesis, which is 
notorious for eating up large quantities of memory 
— a couple of short spoken phrases of about 10 
words each can take up to three or four Kbytes of 
RAM. This example is among the best and clearest 
so far heard on any game. The graphics are also 
very good, and although the rooms are not replete 
with them, the individual details of the agent, the 
furniture and the robots are very finely drawn. 
These various elements add up to a very well 
crafted and enjoyable game. | 
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DESCRIPTION 


6510 On-Chip Data- 
Direction Register 

6510 On-Chip 8-Bit 
Input/Output Register 

Unused 

Jump Vector: Convert 
Floating —Integer 


Jump Vector: Convert 
Integer —Floating 

Search Character 

Flag: Scan for Quote at 
End of String 

Screen Column From Last 
TAB 

Flag: 0 = Load, 1 = Ver- 
ify 

Input Buffer Pointer / No. 
of Subscripts 

Flag: Default Array DI- 
Mension 

Data Type: $FF = String, 
$00 = Numeric 

Data Type: $80 = Integer, 
$00 = Floating 

Flag: DATA scan/LIST 
quote/Garbage Coll 

Flag: Subscript Ref / User 
Function Call 

Flag: $00 = INPUT, $40 
= GET, $98 = READ 


Flag: TAN sign / Compari- 


son Result 


Flag: INPUT Prompt 


Temp: Integer Value 
Pointer: Temporary String 


Stack 
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